草庐IT

php json_encode 不转义新行

全部标签

ruby-on-rails - Ruby - 转义括号

我这辈子都弄不明白,尽管它应该很简单。如何用"\("和替换字符串中所有出现的"("和")""\)"?似乎没有任何效果:"foo(bar)foo".gsub("(","\(")#=>"foo(bar)foo""foo(bar)foo".gsub("(","\\(")#=>"foo\\(bar)foo"有什么想法吗? 最佳答案 第二次尝试时您已经有了解决方案,您只是感到困惑,因为字符串在交互式解释器中以转义形式显示。但实际上只有一个反斜杠,没有两个。尝试使用puts打印它,您会发现实际上只有一个反斜杠:>"foo(bar)foo".gs

ruby - 用于删除下一个/尾随字符的转义序列?

除了使用\x08删除前导字符外,是否可以同时删除尾随字符?是否有一个转义序列将删除下一个字符而不是前一个字符?我看到delete显然映射到ASCII127,即Hex7F,但以下代码:puts"a\x08b\x7fcd"产生b⌂cd我预计\x7f会删除它后面的'c'字符,但它没有。 最佳答案 您实际上并没有使用\x08删除任何内容,您只是用“b”覆盖了“a”。想象一下您使用电传纸质终端的过去。您实际上会在纸上看到的是打印的“a”,电传打字机会备份一个空格,然后在其上打印“b”。所有非打印的ascii码都是为了控制电传纸终端的移动而发明

ruby-on-rails - CGI::escapeHTML 正在转义单引号

我最近将我的Ruby1.9.3升级到2.0.0并感到惊讶;CGI::escapeHTML现在转义单引号,意思是:CGI::escapeHTML("'")=>"'"最奇怪的是,当定义escapeHTML时,一切似乎都很好,复制方法的定义给出了正确的结果(它不转义单引号)有人知道这件事吗?谢谢, 最佳答案 实际上,它执行2.0源代码中定义的操作。但你是对的,实现从1.9.3更改为2.0。1.9.3source:defCGI::escapeHTML(string)string.gsub(/[&\"]/,TABLE_FOR_ESCA

ruby - 将转义的 unicode 字符串转换为 ruby​​ 1.8 中的字符

我必须阅读一些包含以下内容的文本文件:\u201CGushingCross的小贩夫人\u201D在ruby​​1.9终端中,当我创建一个包含以下内容的字符串时:ruby-1.9.1-p378>"\u2714\u2714mygreatstring\u2714\u2714"=>"✔✔mygreatstring✔✔"在ruby​​1.8中,我没有将unicode代码转换为它们的字符:ree-1.8.7-2010.01>"\u2714\u2714mygreatstring\u2714\u2714"=>"u2714u2714mygreatstringu2714u2714"有什么简单的方法可以在R

ruby - 如何从 ruby​​ 中取消转义 c 风格的转义序列?

在ruby​​中,我如何解码c风格的转义序列?例如'\n'到换行符,'\t'到制表符? 最佳答案 好吧,如果你不喜欢eval解决方案,我已经在Ruby中破解了一个简单的状态机来正确解析字符串中的简单“\n”和“\t”,包括预转义反斜杠本身。在这里:BACKSLASH="\\"defunescape_c_string(s)state=0res=''s.each_char{|c|casestatewhen0casecwhenBACKSLASHthenstate=1elseres这个可以轻松扩展以支持更多字符,包括多字符实体,如\123。

ruby - 如何在 Ruby 中插入或更新之前转义字符串

在ruby​​中,ActiveRecord不提供更新和插入sql的动态绑定(bind),当然我可以使用原始sql,但是需要保持连接,所以我想知道是否有更简单的方法在执行之前转义更新或插入sql像下面的代码:ActiveRecord::Base.connection.insert(sql)我想我可以用gsub写代码,但我知道是否有现成的方法来做。 最佳答案 在Rails>=3.2.5中,以下对我有用:evil_input='"\';%#{}\"foo'ActiveRecord::Base.connection.quote(evil_i

ruby-on-rails - Ruby on Rails 似乎是由 link_to 创建的自动转义 html

这是我的代码,我试图用.to_sentence以句子形式显示指向bboy的工作人员的链接列表0)%>1)then"Crew".pluralizeelse"Crew"end%>:Independent我得到的输出是正确的链接,但它显示为:HustleKidzandKnuckleheadsCali而不是:HustleKidzandKnuckleheadsCali转义了html,而不是所需的链接。我错过了什么吗?我试过CGI.unescapeHTML和其他几个,但我迷路了...... 最佳答案 Rails3现在自动转义一切,为了输出原始H

ruby - 在我的 ramaze 应用程序上显示 £ 符号时,我收到 "incompatible character encodings: CP850 and UTF-8"

在我的ramaze应用程序上显示£符号时,我收到“不兼容的字符编码:CP850和UTF-8”。我怎样才能摆脱这个错误?我的head标签中有UTF-8元标签。当我用键盘输入£符号时会发生这种情况。看。我已将以下代码放入我的ruby​​文件中,但没有解决问题。#encoding:UTF-8Encoding.default_external='utf-8'Encoding.default_internal=Encoding::UTF_8 最佳答案 尝试强制编码以查看是否可以解决问题:your_string.force_encoding(:

Ruby:将转义字符串写入 YAML

以下...require'yaml'test="I'mab&dstring"File.open('test.yaml','w')do|out|out.write(test.to_yaml)end...输出...---thisisab&dstring如何让它输出---'thisisab&dstring'??? 最佳答案 如果你想在YAML中存储转义字符串,在将其转换为YAML之前使用#inspect对其进行转义:irb>require'yaml'=>trueirb>str=%{Thisstring'salittlecomplicate

Ruby String.encode 仍然给出 "invalid byte sequence in UTF-8"

在IRB中,我正在尝试以下操作:1.9.3p194:001>foo="\xBF".encode("utf-8",:invalid=>:replace,:undef=>:replace)=>"\xBF"1.9.3p194:002>foo.match/foo/ArgumentError:invalidbytesequenceinUTF-8from(irb):2:in`match'知道出了什么问题吗? 最佳答案 我猜"\xBF"已经认为它是用UTF-8编码的,所以当你调用encode时,它认为你正在尝试编码一个UTF-8中的UTF-8字符